<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>wazanHub</title>
  <meta name="renderer" content="webkit" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>

<meta http-equiv="Cache-Control" content="no-transform" />
<meta http-equiv="Cache-Control" content="no-siteapp" />

<meta name="theme-color" content="#f8f5ec" />
<meta name="msapplication-navbutton-color" content="#f8f5ec">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="#f8f5ec">


<meta name="author" content="wazan" /><meta name="description" content="Hugo theme even example site。" /><meta name="keywords" content="wazan, study" />






<meta name="generator" content="Hugo 0.70.0 with theme even" />


<link rel="canonical" href="http://wazan.gitee.io/blog/" />
  <link href="http://wazan.gitee.io/blog/index.xml" rel="alternate" type="application/rss+xml" title="wazanHub" />
  <link href="http://wazan.gitee.io/blog/index.xml" rel="feed" type="application/rss+xml" title="wazanHub" />
<link rel="apple-touch-icon" sizes="180x180" href="/blog/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/blog/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/blog/favicon-16x16.png">
<link rel="manifest" href="/blog/manifest.json">
<link rel="mask-icon" href="/blog/safari-pinned-tab.svg" color="#5bbad5">



<link href="/blog/sass/main.min.b70575932d58f00331c6aacffef9d6f69bd146e84ff98ee769622d3439951b79.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.css" integrity="sha256-7TyXnr2YU040zfSP+rEcz29ggW4j56/ujTPwjMzyqFY=" crossorigin="anonymous">


<meta property="og:title" content="wazanHub" />
<meta property="og:description" content="Hugo theme even example site。" />
<meta property="og:type" content="website" />
<meta property="og:url" content="http://wazan.gitee.io/blog/" />
<meta property="og:updated_time" content="2020-06-02T22:46:00+08:00" />
<meta itemprop="name" content="wazanHub">
<meta itemprop="description" content="Hugo theme even example site。"><meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="wazanHub"/>
<meta name="twitter:description" content="Hugo theme even example site。"/>

<!--[if lte IE 9]>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/classlist/1.1.20170427/classList.min.js"></script>
<![endif]-->

<!--[if lt IE 9]>
  <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
<![endif]-->

</head>
<body>
  <div id="mobile-navbar" class="mobile-navbar">
  <div class="mobile-header-logo">
    <a href="/blog/" class="logo">wazanHub</a>
  </div>
  <div class="mobile-navbar-icon">
    <span></span>
    <span></span>
    <span></span>
  </div>
</div>
<nav id="mobile-menu" class="mobile-menu slideout-menu">
  <ul class="mobile-menu-list">
    <a href="/blog/">
        <li class="mobile-menu-item">首页</li>
      </a><a href="/blog/post/">
        <li class="mobile-menu-item">归档</li>
      </a><a href="/blog/tags/">
        <li class="mobile-menu-item">标签</li>
      </a><a href="/blog/categories/">
        <li class="mobile-menu-item">分类</li>
      </a><a href="/blog/about/">
        <li class="mobile-menu-item">关于</li>
      </a>
  </ul>
</nav>
  <div class="container" id="mobile-panel">
    <header id="header" class="header">
        <div class="logo-wrapper">
  <a href="/blog/" class="logo">wazanHub</a>
</div>

<nav class="site-navbar">
  <ul id="menu" class="menu">
    <li class="menu-item">
        <a class="menu-item-link" href="/blog/">首页</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/post/">归档</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/tags/">标签</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/categories/">分类</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/blog/about/">关于</a>
      </li>
  </ul>
</nav>
    </header>

    <main id="main" class="main">
      <div class="content-wrapper">
        <div id="content" class="content">
          <section id="posts" class="posts">
    <article class="post">
  <header class="post-header">
    <h1 class="post-title"><a class="post-link" href="/blog/post/v-chat/">一个简单的仿群聊h5交互小页面</a></h1>
    <div class="post-meta">
      <span class="post-time"> 2020-06-08 </span>
      <div class="post-category">
          <a href="/blog/categories/vue/"> vue </a>
          </div>
    </div>
  </header>
  
  <div class="post-content">
    <div class="post-summary">
      介绍  之前某祺汽车客户搞系列线上留资活动，其中有个类似机器人的仿微信群聊h5需求,提前用jq写出来了，可以说完成了基本的功能(也没什么功能)。后来听说需求腰斩没上线，闲来有空用vue重构下(其实这么简单的h5似乎没必要用vue来做，这里是自己因为对vue的不熟悉，以此来练习并加对知识点的总结)线上地址
或扫码体验
结果都一样,最重要的是过程 参考案例是大概是小米做的一个互动h5页面。在下
原需求分析  入口添加用户名或者先微信授权进入，获取微信头像，名称等信息 进入活动页面，显示日常微信进群的样式，自动进行开场对白聊天 首段聊天对白结束后，底下输入功能区变为若干提问的问题点，手动点击又会出现自动的对白聊天  开干思路 主要开发点：  切换计算渲染相应内容的容器组件尺寸 每出一条最新对话记录使聊天页面滑到最底处 定时加载输出既定对白记录 注意点：每段对白结束前不可点击下面的提问按钮 vue元素获取 容器各种高度  代码回顾 这里大概说下过程中的思路和遇到的问题点，不对着逻辑代码做一段一段review，感觉语焉不祥，所以都写在代码的注释里
1.vue-cli搭建项目 2.确定组件结构 一级：App
二级：Main(聊天记录展示区)、Bottom(底部控制输出区)
三级：Record(每段对白群)
3.页面容器尺寸分配渲染 明显Bottom的高度无论横屏竖屏都应该是固定的，变化的是Main的高度。这里写个方法在初始化或者监听窗口发生变化时计算并渲染这两块容器的高度做法：在App钩子函数mounted里使用这个方法钩子用法在父组件App渲染完成即App mounted后(子组件已在此之前mounted完)，开始调用frameChange()里的frameInit(),得到组件Main的高度=窗口的高度-确定的底部Bottom组件的高度 mounted(){this.frameChange()} frameChange() // 尺寸变化所做操作frameInit() //计算并渲染布局Main尺寸对白数据从哪里来 Mockjs模拟接口数据Mock数据用法在子组件Record的mouted里调用createData获取数据钩子用法 vuex的应用
&lt;!--Record--&gt;mounted(){this.createData()}使用vuex创建一个公共状态 写一个Promise执行从获取到渲染数据的过程Main的子组件Record,即每条记录的展示 1.进来自动加载一段对白2.实现定时加载这段对白里的每条内容3.在使用定时器加载的时间里控制底下Bottom组件不能被点击(在这里就不review这部分的代码了,在源码里作了详细注释,感觉结合代码更利于理解)
项目总结 通过这个小练习对vue的一些api在项目的使用有了个认识
1.对于组件及其组件里的节点的获取
2.对组件的钩子函数的理解与应用
3.对于mockjs的使用
4.对于promise的使用
5.对于vuex的使用
源码地址 v-chat仓库地址
    </div>
    <div class="read-more">
      <a href="/blog/post/v-chat/" class="read-more-link">阅读更多</a>
    </div>
  </div>
</article>

    <article class="post">
  <header class="post-header">
    <h1 class="post-title"><a class="post-link" href="/blog/post/js-%E5%8E%9F%E7%90%86%E5%B1%82%E6%B7%B1%E5%85%A5/">JS深入系列</a></h1>
    <div class="post-meta">
      <span class="post-time"> 2020-06-02 </span>
      <div class="post-category">
          <a href="/blog/categories/js/"> js </a>
          </div>
    </div>
  </header>
  
  <div class="post-content">
    <div class="post-summary">
      type 和 instanceof typeof 基本类型和引用类型
   类型 值     Undefined &ldquo;undefined&rdquo;   Null &ldquo;object&rdquo; (历史遗留问题)   Boolean &ldquo;boolean&rdquo;   Number &ldquo;number&rdquo;   String &ldquo;string&rdquo;   Object Array &ldquo;object&rdquo;    instanceof 运算符用来测试一个对象在其原型链中是否存在一个构造函数的 prototype 属性。
使用两者结合封装函数来判断类型
function getDataType(obj) {if(obj === null){return &quot;null&quot;;}else if(typeof obj === &quot;object&quot;){if(obj instanceof Array){return &quot;array&quot;;}else{return &quot;object&quot;;}}else{return typeof obj;}}原型 在典型的oop（面向对象编程）的语言中，如java,都存在类的概念，类就是对象的模板，对象就是类的实例。
    </div>
    <div class="read-more">
      <a href="/blog/post/js-%E5%8E%9F%E7%90%86%E5%B1%82%E6%B7%B1%E5%85%A5/" class="read-more-link">阅读更多</a>
    </div>
  </div>
</article>

    </section>
  
  <nav class="pagination">
    <a class="prev" href="/blog/">
        <i class="iconfont icon-left"></i>
        <span class="prev-text">上一页</span>
      </a>
    
  </nav>
        </div>
        

      </div>
    </main>

    <footer id="footer" class="footer">
      <div class="social-links">
      <a href="mailto:your@email.com" class="iconfont icon-email" title="email"></a>
      <a href="http://localhost:1313" class="iconfont icon-github" title="github"></a>
      <a href="http://localhost:1313" class="iconfont icon-zhihu" title="zhihu"></a>
  <a href="http://wazan.gitee.io/blog/index.xml" type="application/rss+xml" class="iconfont icon-rss" title="rss"></a>
</div>

<div class="copyright">
  <span class="power-by">
    由 <a class="hexo-link" href="https://gohugo.io">Hugo</a> 强力驱动
  </span>
  <span class="division">|</span>
  <span class="theme-info">
    主题 - 
    <a class="theme-link" href="https://github.com/olOwOlo/hugo-theme-even">Even</a>
  </span>

  

  <span class="copyright-year">
    &copy; 
    2019 - 
    2020
    <span class="heart">
      <i class="iconfont icon-heart"></i>
    </span>
    <span class="author">wazan</span>
  </span>
</div>
    </footer>

    <div class="back-to-top" id="back-to-top">
      <i class="iconfont icon-up"></i>
    </div>
  </div>
  <script src="/blog/lib/highlight/highlight.pack.js?v=20171001"></script>
  <script src="https://cdn.jsdelivr.net/npm/jquery@3.2.1/dist/jquery.min.js" integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/slideout@1.0.1/dist/slideout.min.js" integrity="sha256-t+zJ/g8/KXIJMjSVQdnibt4dlaDxc9zXr/9oNPeWqdg=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.js" integrity="sha256-XVLffZaxoWfGUEbdzuLi7pwaUJv1cecsQJQqGLe7axY=" crossorigin="anonymous"></script>



<script type="text/javascript" src="/blog/js/main.min.d7b7ada643c9c1a983026e177f141f7363b4640d619caf01d8831a6718cd44ea.js"></script>








</body>
</html>
